package com.wgh.product.mapper;

import com.wgh.product.entity.shop.Brand;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 品牌Mapper接口
 * 
 * @author AI Shop
 */
@Mapper
public interface BrandMapper extends BaseMapper<Brand> {

    /**
     * 查询启用的品牌
     * 
     * @return 启用的品牌列表
     */
    @Select("SELECT * FROM shop_brand WHERE status = 1 AND del_flag = 0 ORDER BY sort ASC")
    List<Brand> selectEnabledBrands();

    /**
     * 根据品牌名称查询品牌
     * 
     * @param name 品牌名称
     * @return 品牌信息
     */
    Brand selectByName(@Param("name") String name);

    /**
     * 根据品牌首字母查询品牌
     * 
     * @param firstLetter 品牌首字母
     * @return 品牌列表
     */
    List<Brand> selectByFirstLetter(@Param("firstLetter") String firstLetter);

    /**
     * 更新品牌状态
     * 
     * @param ids 品牌ID列表
     * @param status 状态
     * @return 影响行数
     */
    int updateStatusBatch(@Param("ids") List<Long> ids, @Param("status") Integer status);

    /**
     * 查询品牌关联的商品数量
     * 
     * @param brandId 品牌ID
     * @return 商品数量
     */
    int countProductsByBrandId(@Param("brandId") Long brandId);

    /**
     * 搜索品牌
     * 
     * @param keyword 搜索关键词
     * @return 品牌列表
     */
    List<Brand> searchBrands(@Param("keyword") String keyword);
}